草庐IT

Android AsyncTask 内存泄漏

全部标签

c++ - 它会导致内存泄漏吗?

我写了这段代码:stringgetWinTitle(HWNDhwnd){constintMAX_LENGTH=1000;wchar_ttitle[MAX_LENGTH];ZeroMemory(title,MAX_LENGTH);GetWindowText(hwnd,(LPWSTR)title,MAX_LENGTH);char*buffer=newchar[MAX_LENGTH];wcstombs(buffer,title,MAX_LENGTH);stringres=buffer;returnres;}这里有内存泄漏吗?我需要释放ZeroMemory分配的内存吗?我是否需要显式释放分配给

你可以使用用mingw编译的程序访问其他程序的内存吗?

我在Windows8.1上编写了这个非常简单的程序,并使用Mingw的gcc对其进行了编译。我用“test.exe>t.txt”和“test.exe>t1.txt”运行它,输出不同(即使它使用虚拟地址)。它跑了一会儿,然后就崩溃了。我决定对此进行测试,因为我正在阅读一本关于操作系统的书。是否正在读取其他程序的内存?那不是不应该发生的吗?我可能误解了什么......#includeintmain(intargc,char*argv[]){intr=0;intp[4]={1,5,4,3};for(r=0;p[r]!=1111111111111111;r++){p[2]=p[r];print

c++ - 是否可以在 2GB 以上的文件上创建更小的内存映射 View ?

我已经为Windows和Linux编写了一个C++类,它为任意大小n的文件创建一个内存映射View。类构造函数的代码canbeseenhere.我目前正在Windows32位XP上测试代码。我发现对于大小为0=2GB的文件大小,MapViewOfFile返回NULL值和错误代码8,“没有足够的存储空间可用于处理此命令”。显然,Windows无法在该进程中找到大小为2GB的可用地址空间。因此,我可能需要修改类构造函数以创建一组较小的内存映射View,总计>=2GB字节&&之前,我使用下面的代码进行随机访问:char*KeyArray;try{mmapFile=newcMemoryMapp

C内存题

charbuffer[10];strcat(buffer,"hi");printf("%s",buffer);在上面的代码中,它打印了一些奇怪的符号或数字,后跟“hi”,我知道strcat正在附加到缓冲区。我通常将缓冲区中的内存归零。但我很好奇为什么我通常必须这样做。如果我在没有strcat的情况下执行printf("%i",buffer);,它只会打印一个随机数。那个数字是多少?在我填充任何东西之前,任何人都可以解释或链接到解释缓冲区中内容的tut吗? 最佳答案 “缓冲区”是堆栈上的一个10字节区域,它包含最后写入该内存区域的所有

windows - Delphi 7 写进程内存

这是我的工作代码DriftMul:=99;WriteProcessMemory(HandleWindow,ptr($4E709C),@DriftMul,2,Write);我想在不使用变量的情况下转换它,但它不会工作下面只是我想做的一个例子。WriteProcessMemory(HandleWindow,ptr($4E709C),ptr(99),2,Write);有谁知道使用变量来完成这项工作的方法吗???我可以用几种语言编程,我使用的每一种语言都是方法来做到这一点。我想这样做的原因是因为我要制作一个大程序,它会编写大量不同的值,它将为我节省大约300多行代码。下面是我使用的C++示例。

c# - 如何保护进程的内存

我有一个进程,在内存中会有一些重要的值。我不希望任何人能够读取我的进程的内存并获取这些值。所以我试图创建一个程序来查看正在运行的程序列表并确定其中是否有任何程序是“调试器”等。但我意识到有人可以编写一个快速程序来转储我的进程的内存。我知道我系统上的几个进程的内存受到保护。我怎么也能得到这个?(ps:我用的是C#) 最佳答案 任何在具有足够权限的用户(例如本地管理员)下运行的应用程序都可以调用ReadProcessMemory并随时随意阅读您的流程,而无需附加到您的流程调试端口,并且您的处理无法阻止甚至检测到这一点。我什至没有深入探讨

windows - 如何从 Windows 应用程序内存中读取一些数据?

我有一个应用程序,可以显示一些数据。我需要附加到这个应用程序的进程,在内存中找到我需要的数据(实际上是一个数字),并将其保存在某个地方。这个应用程序似乎没有使用标准的Windows控件,所以事情不会像使用AutoIt或类似的东西读取控件数据那么简单。目前我是一名自学数据库的人,对Windows应用程序调试的了解很浅。甚至不确定我是否足够正确地问我的问题。那么,您能否给我一些入门指南,例如,我应该首先阅读什么,以及我应该遵循的一般方向?谢谢。 最佳答案 要读取其他应用程序的内存,您需要根据OpenProcess打开进程至少具有PROC

windows - 告诉故事内存碎片的迹象(而不是内存泄漏)?

首先我意识到泄漏会导致内存严重碎片化,但请耐心等待。使用WinDbg并附加到进程:使用!heap(或另一个WinDbg命令),如果我正在处理内存碎片而不是泄漏,我应该期待什么?例如,我可以使用“!heapstat”和“!heapstat-hhandle”来归零产生泄漏的代码;但是在这些相同的返回值中是否有暗示碎片化的东西?XP和Vista之间的内存分配是否发生了根本性变化?特别是与DLL和其他库加载有关?我们一直只在XP上开发,所以我不熟悉Vista,但事实证明,当我们在Vista上安装相同的二进制文件时,我们在XP上看到的某些内存问题就会消失。谢谢! 最佳

c++ - 内存删除的运行时检测

代码:int*ptr=newint[10];int*q=ptr;deleteq;工作正常,没有任何问题(没有运行时错误)。但是,下面的代码:int*ptr=newint[10];int*q=ptr;q++;deleteq;导致运行时错误。我使用MicrosoftVisualStudio-8和Win-7作为平台。我无法弄清楚为什么在第二种情况下会出现运行时错误? 最佳答案 您的代码导致了未定义的行为。未定义的行为意味着任何事情都可能发生,无法定义行为。该程序的运行完全靠运气,它的行为无法解释。基本上,如果您使用new分配动态内存,您必

c++ - 我如何找到 Win32 中的资源泄漏?

运行几个小时后,我的应用程序无法创建新的字体对象:CreateFontIndirect()returnsNULL.我知道如何查找内存泄漏(即使用并行检查器或其他分析器-其中大部分包括泄漏检测)。但是如何定位Win32中的资源泄漏? 最佳答案 为自己准备一份GDIView-这个有用的工具可以显示您的应用程序使用的所有GDI对象,包括字体名称、大小等详细信息。这在过去被证明非常方便。对于Win32应用程序,您可能需要查看WTL框架-它使用轻量级C++类包装GDI对象,为您处理对象删除。 关于